<template>
	<view>
		<view class="smart-panel-head">
			<view class="smart-panel-head-title">form</view>
		</view>
		<form @submit="formSubmit" @reset="formReset">
			<view class="uni-form-item uni-column">
				<view class="title">姓名</view>
				<input class="uni-input" name="nickname" placeholder="请输入姓名:" />
			</view>
			<view class="uni-form-item uni-column">
				<view class=title>性别</view>
				<radio-group name="gender">
					<radio value="man" checked="true"></radio>男
					<radio value="man"></radio>女
				</radio-group>
			</view>
			<view class="uni-form-item uni-column">
				<view class=title>爱好</view>
				<checkbox-group name="loves">
					<checkbox checked="true"></checkbox>读书
					<checkbox></checkbox>写字
				</checkbox-group>
			</view>
			<view class="uni-form-item uni-column">
				<view class=title>年龄</view>
				<slider value="20" name="age" show-value=""></slider>
			</view>
			<view class="uni-btn-v">
				<button form-type="submit">Submit</button>
				<button type="default" form-type="reset">Reset</button>
			</view>
		</form>
	</view>
</template>

<script>
	export default {
		data() {
			return {

			}
		},
		methods: {
			formSubmit: function(e) {
				console.log('form发生了submit事件,携带数据为:' + JSON.stringify(e.detail.value))
				var rule = [{
						name: "nickname",
						checkType: "string",
						checkRule: "1, 3",
						errorMsg: "姓名应为1-3"
					},
					{
						name: "gender",
						checkType: "in",
						checkRule: "男，女",
						errorMsg: "请选择性别"
					},
					{
						name: "Loves",
						checkType: "notnull",
						checkRule: "",
						errorMsg: "请选择爱好"
					},
				];
				var formData = e.detail.value;
				var checkRes = graceChecker.check(formData, rule);
				if (checkRes) {
					uni.showToast({
						title: "验证通过",
						icon: 'none'
					});
				} else {
					uni.showToast({
						title: graceChecker.error,
						icon: "none"
					});
				}
				uni.shouModal({
					content: '表单数据内容：' + JSON.stringify(e.detail.value),
					showCancel: false
				});
			},
			formReset: function(e) {
				console.log('清空数据')
			}
		}
	}
</script>

<style>
	
	.uni-column{
		margin: 30rpx 20rpx;
	}
	.uni-input{
		background-color: aliceblue;
		height: 80rpx;
		margin-top: 20rpx;
	}
	.title{
		margin-bottom: 20rpx;
	}
</style>